[CLSCompliantAttribute(false)]public static void CompressRows(ushort[] runBuffer,IntPtr buffer,int width,int rows)
[CLSCompliantAttribute(false)]public:static void CompressRows(array<ushort>^ runBuffer,IntPtr buffer,int width,int rows)
runBuffer
The output buffer, which will be filled with 1-bit compressed image data.
buffer
The unmanaged input buffer, which contains the 1-bit image data to be compressed.
width
The number of pixels to process.
rows
The number of rows to process.
. Use this method to process multiple lines of image data. This method is available in the Document/Medical Toolkits.
This function is useful for working with 1-bit images that are loaded in their compressed formats for faster loading and display. For more information, refer to Speeding Up 1-Bit Documents.
using Leadtools;using Leadtools.Codecs;using Leadtools.ImageProcessing;using Leadtools.ImageProcessing.Core;using Leadtools.ImageProcessing.Color;using Leadtools.Dicom;using Leadtools.Drawing;using Leadtools.Controls;using Leadtools.Svg;public void GetRowCompressedExample(){RasterCodecs codecs = new RasterCodecs();// Load the bitmap, at 1 bit per pixel, compressedcodecs.Options.Load.Compressed = true;RasterImage image = codecs.Load(Path.Combine(LEAD_VARS.ImagesDir, "OCR1.TIF"), 1, Leadtools.Codecs.CodecsLoadByteOrder.Bgr, 1, 1);// This example does not work with rotated view perspectives.if ((image.ViewPerspective != RasterViewPerspective.TopLeft) || (image.ViewPerspective != RasterViewPerspective.BottomLeft))image.ChangeViewPerspective(RasterViewPerspective.TopLeft);// Adjust the YOffset if the view perspective is bottom left.int nRow = 500; // first row to get.int nYSize = 500; // number of rows to get.if (image.ViewPerspective == RasterViewPerspective.BottomLeft)nRow = image.Height - nRow - nYSize;// Allocate the buffers.byte[] pBuffer = new byte[Convert.ToInt32((((image.Width + 31) & ~(31)) / 8)) * nYSize]; // Buffer to hold the expanded row.ushort[] pRunBuffer = new ushort[((image.Width + 3) * 2) * nYSize]; // Buffer to hold the compressed row.if (image.IsGlobalMemory)image.Access();// Get the top nRow lines.image.GetRowCompressed(null, pRunBuffer, 0, nRow, nYSize);// Expand the compressed data.RasterRleCompressor.ExpandRows(pRunBuffer, pBuffer, 0, image.Width, nYSize);// Invert the data.for (int n = 0; n < (image.BytesPerLine * nYSize); n++)pBuffer[n] ^= 0xff;// Compress the inverted data.RasterRleCompressor.CompressRows(pRunBuffer, pBuffer, 0, image.Width, nYSize);// Put the inverted, compressed data back into the image.image.SetRowCompressed(null, pRunBuffer, 0, nRow, nYSize);if (image.IsGlobalMemory)image.Release();codecs.Save(image, Path.Combine(LEAD_VARS.ImagesDir, "IMAGE1_getrowcompresed.BMP"), RasterImageFormat.Bmp, 0);image.Dispose();codecs.Dispose();}static class LEAD_VARS{public const string ImagesDir = @"C:\LEADTOOLS22\Resources\Images";}
Help Collections
Raster .NET | C API | C++ Class Library | HTML5 JavaScript
Document .NET | C API | C++ Class Library | HTML5 JavaScript
Medical .NET | C API | C++ Class Library | HTML5 JavaScript
Medical Web Viewer .NET
Multimedia
Direct Show .NET | C API | Filters
Media Foundation .NET | C API | Transforms
Supported Platforms
.NET, Java, Android, and iOS/macOS Assemblies
Imaging, Medical, and Document
C API/C++ Class Libraries
Imaging, Medical, and Document
HTML5 JavaScript Libraries
Imaging, Medical, and Document
